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(54) Mum-program execution controlling apparatus and method 

(57) A storage section (6. 7, 6) stores a plurality of 
programs. A central processing section (5) controls exe- 
cution of each of the plurality of programs stored in the 
storage section (6, 7, 8). A setting section, in coopera- 
tion with the central processing section (5), sets at least 
one of a disable area that Inhibits accessing of another 
program and an enable area that allows accessing of 
another program, In each of the plurality of programs 
stored in the storage section (6, 7, 8). 
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Description 

The present invention generally relates to a multi- 
program execution controlling apparatus and method, 
and more particularly to a mufti-program execution con- 
trolling apparatus and method which inhibit a program 
currently being executed from unnecessarily accessing 
another program in a one-chip microcomputer having a 
plurality of programs. 

For portable data carriers, such as IC cards or wire- 
less cards, the security of their programs and data has 
been considered Important. 

In one-chip microcomputers used for such portable 
data carriers, a single main program is allocated to a 
single semiconductor chip. Even when rt has a plurality 
of programs, these programs are used to act as exten- 
sion of the main program or part of the main program's 
function in the form of subroutines. 

With program execution controlling techniques for 

information on the running ones of the plurality of pro- 
grams are sent to the central processing unit (CPU) in 
the one-chip microcomputer, which thereby informs 
which program is now being executed, making it possi- 
ble to manage the programs there. 

Persons qualified to create programs to be installed 
in 6uch one-chip microcomputers are restricted to those 
who are familiar with the operating system (OS) of the 
one-chip microcomputers and manage, own, and set] 
the one-chip microcomputers, or to those who have 
been asked to develop and create the programs and 
know the OS for aO the programs. 

Here, the OS for a one-chip microcomputer is not 
the OS for tie CPU itself in the one-chip microcomputer, 
but a chip OS that takes the form of an algorithm of a 
program corresponding to an application and is used in 
a system and that defines com man d usage and data 
management method in a manner that determines how 
to access wNch data at which address in the memories 
around the CPU. 

The instruction organization or OS for the CPU 
itself has been made public. 

With the techniques for controlling the execution of 
multiple programs on the conventional one-chip micro- 
computer, the CPU can recognize the program being 
executed in the case of normal programs that teD their 
own IDs to the CPU according to the specific rules. 
When a program does not follow the specific rules, how- 
ever, this causes the problem that the CPU cannot rec- 
ognize the program being executed. 

Furthermore, with the techniques for controlling the 
execution of muttyf e programs on the conventional one- 
chip microcomputer. H is imposstoJe to Inhibit one pro- 
gram being executed from accessing anofrer program, 
and moreover, there is no need to do that Conse- 
quently; when another invalid program has been written 
in the memory addresses, there is a possibility that the 
preceding program is rewritten, read out or executed, 
which cannot be avoided technically. 



Still furthermore, with the techniques for controlling 
the execution of multiple programs on the conventional 
one-chip rrtcrooomputer, when persons other than the 
aforementioned persons are asked to write programs, 

s the chip OS of the one-chip rmcrooorrputer must be 
made known to the programmers. Accordingly, there is 
a strong possfoflrty that the contents of the system will 
leak out which is unfavorable in terms of security and 
makes it technically impossible to prevent unauthorized 

10 use of the contents from being made easily. 

ft is, therefore, an object of the present Invention to 
provide a new and improved murti-program execution 
controlling apparatus and method which control the exe- 
cution of programs in a one-chip mkTOCorrputer having 

is a plurality of programs in a manner trot not only inhibits 
a program from unnecessarily accessing another pro- 
gram in executing programs, but also increases the 
security of the programs and data. 

According to a first aspect of the present invention, 
there te^arovkteo^ 

apparatus comprising: storage means for storing a plu- 
rality of programs; central processing means for control- 
ling execution of each of the plurality of programs stored 
in the storage means; and setting means, in coopera- 

25 ton wfth fie central processing means, for setting at 
least one of a disable area that Inhibits the accessing of 
another program and an enable area that allows 
accessing of another program, tn each of the plurality of 
programs stored In the storage means. 

30 According to a second aspect of the present inven- 
tion, there is provided a rruirfr program execution con- 
trolling apparatus comprising: storage means for storing 
a plurality of programs; central processing means for 
controlling execution of each of the plurality of programs 

3$ stored in the storage means; setting means, in cooper- 
ation with the central processing means, for setting a 
disable area that inhibits accessing of another program 
in each of the plurality of programs stored in the storage 
means; and control means, in cooperation with the cen- 

40 tral processing means, for at least one of interrupting to 
the central processing means and inhibiting access to 
the storage means, when an attempt is made to access 
the disable area of another program while one of the 
plurality of programs stored in the storage means is 

45 being executed. 

According to a third aspect of the present invention, 
there is provided a multi-program execution controlling 
apparatus comprising: storage means for storing a plu- 
rality of programs; centra) processing means for control- 

so ting execution of each of the plurality of programs stored 
In the storage means; program ID Identifying means, in 
cooperation wfth the central processing means, for Iden- 
tifying an ID of a program to be executed of the plurality 
of programs stored in the storage means; program area 

55 setting means, in cooperation with the central process- 
ing means, for setting an area that allows accessing of 
a program to be executed of the plurality of programs 
stored in the storage means; start address setting 
means, in cooperation with the centra) processing 
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means, for setting an address at which operation wiQ 
start when operation is switched to a program to be exe- 
cuted; address sensing means for comparing the 
address set at the program area setting means with an 
address being accessed by the program currently being 5 
executed to sense whether it is an enable address or a 
disable address; interrupt signal generator means for. 
when a sensing result of the address sensing means 
shows that it is a disable address, generating a signal to 
interrupt to the central processing means on the basis of 10 
the sensing result; and memory access disable signal 
generator means for, only when a sensing result of the 
address sensing means shows that access is intended 
for a disable address, generating a signal to inhibit 
access to the storage means corresponding to the disa- 15 
ble address. 

According to a fourth aspect of the present inven- 
tion, there is provided a mutti -program execution con- 
trolling method cornprising the steps of: identifyi ng, in 
^cooperation wnrrax£rrtra!prcx^ 
program to be executed of a plurality of programs stored 
in a storage means; setting, in cooperation with the cen- 
tral processing means, an area that allows accessing of 
a program to be executed of the plurality of programs 
stored in the storage means; setting, in cooperation with ss 
the central processing means, an address at which 
operation will start when operation is switched to a pro- 
gram to be executed; comparing the address set at the 
setting step with an address being accessed by the pro- 
gram currently being executed to sense whether It is an 30 
enable address or a disable address; generating a sig- 
nal to interrupt to the central processing means, when a 
sensing result at the sensing step shows thai the 
access is indented for a disable address, on the basis of 
the sensing result; and generating a signal to inhibit 35 
access to the storage means corresponding to the disa- 
ble address, only when a sensing result at the sensing 
step shows that access is intended for a disable 



With the multi-program execution controlling appa- 40 
ratus according to the fast aspect of the present inven- 
tion, tie setting means sets at least one of a disable 
area that inhibits each program from being accessed by 
another program and an enable area that allows each 
program to be accessed by another program. 4$ 

With the multi-program execution corttrolBng appa- 
ratus according to the second aspect of the present 
invention, the setting means sets a disable area that 
inhibits each program from being accessed by another 
program, the control means at least one of interrupts to so 
the central processing unit and inhabits access to the 
storage means, when a program currently being exe- 
cuted of the plurality of programs attempts to access the 
disable area of another program. 

With the multi-program execution controlling appa- ss 
ratus according to the third aspect of the present inven- 
tion, in the program access enable area setting means, 
the program ID identifying means identifies the ID of a 
program to be executed of the plurality of programs, the 



program area setting means sets an area that allows 
the program to access, and the start address setting 
means sets an address at which operation will start 
when control is switched to the program. 

Then, in the program access control means, the 
address sensing means compares tie address set at 
the program area setting means with the address being 
accessed by the program currently being executed to 
sense whether it is an enable address or a disable 
address, the Interrupt signal generator means, when the 
sensing result from the address sensing means shows 
ftat it is a disable address, generates a signal to Inter- 
rupt the central processing unit on the basis of the 
sense signal, and the memory access disable signal 
generator means, only when the sensing result from the 
address sensing means shows that the access is 
intended for a disable address, generates a signal to 
inhibit access to the storage means corresponding to 
the disable address, 
~-- Wrth^ e-~nt utt-pr<^^ 
method according to the fourth aspect of the present 
invention, the ID of a program to be executed of the plu- 
ra&ty of programs is identified, an area that allows the 
accessing of the program is set an address at which 
operation will start when control is switched to the pro- 
gram is set, the set address is compared with the 
address being accessed by the program cunently being 
executed to sense whether the address is an enable 
address or a disable sddress, and when the sensing 
result shows that ft Is a disable address, a signal to Inter- 
rupt the control processing means is generated on the 
basis of the sense signal, and only when the sensing 
result shows the access is intended for a disable 
address, a signal to inhfcrt access to the storage means 
corresponding to the disable address is generated. 

This invention can be more fully understood from 
the following detailed description when taken in con- 
junction with the accompanying drawings, in which: 

FIG. 1 is a block diagram of the main part of a one- 
chip microcomputer having a pluraGty of programs 
to which a multi-program execution controlling 
apparatus according to an embodiment of the 
present invention is applied; 
FIQ. 2 is a memory map to help explain access to 
memory in the mufti-program execution controlling 
apparatus of the present invention; 
FIG. 3 is a memory map to help explain access to 
memory In the multi-program execution controlling 
apparatus of the present Invention; 
FIG. 4 Is a memory map to help explain access to 
memory in the multi-program execution controlling 
apparatus of the present Invention; and 
FIG. 5 is a memory map to help explain access to 
memory in the multi-program execution contrdfing 
apparatus of the present invention. 

Reference will now be made in detail to the pres- 
ently preferred embodiment of the invention as Hlus- 
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trated In the accompanying drawings, in which Gke 
reference characters designate tike or corresponding 
parts throughout the several drawings. 

Hereinafter, an embodiment of the present inven- 
tion wfll be descrfred. 

FIGL 1 is a block diagram of the main part of a one- 
chip microcomputer having a plurality of programs to 
which a mufti-program execution controlling apparatus 
according to an embodiment of the present Invention is 
applied. 

As shown in FIG. 1, the outputs of a first and sec- 
ond program access enable area setting circuits 1 and 2 
are connected to the ir^uts of a program access control 
circuit 3. The output of the program access control cir- 
cuit 3 is connected to the input of a system control cir- 
cuit 4. 

The output of the system control circuit 4 is con- 
nected to the input of each of a central processing unit 
(CPU) 5, a read-only memory (ROM) 6. a random 

as an electrically erasable programmable BOM (EEP- 
ROM) 8. 

The system control circuit 4 is also oormected bilat- 
erally to each of the first and second program access 
enable area setting circuits 1, 2. 

The output of the CPU 5 i6 connected to an address 
bus 9. The address bus 9 is connected to the input of 
each of the ROM 6, RAM 7, EEPROM 8, system control 
circuit 4, and the program access control circuit 3. 

The output of the ROM 6 is connected to a data bus 
10. The data bus 10 is connected to each of the system 
controller 4. CPU 5, RAM 7, and EEPROM 8. 

As describe above, the multi-program execution 
cut id ul ling apparatus of the embodiment is provided 
with the first and second program access enable area 
setting circuits 1, 2 and the program access control cir- 
cuit 3 in order to sense the accessing state of each pro- 
gram in the one-chip microcomputer having a plurality of 
programs and prevent a program from unnecessarily 
accessing another program. 

The first program access enable area setting circuit 
1 specifically comprises a program ID identifying regis- 
ter la, a program area setting register 1c, and a start 
address register 1b. 

In the program ID identifying register 1a, an ID indi- 
cating which program is to be executed is set. 

The program area setting register 1c is a register in 
which an address of an area that allows the accessing 
of the program Is set 

The start address register 1b is a register in which 
an address at which the program wfll start when control 
is passed to the program, is set 

The configuration of each register holds true for the 
second program access enable area setting circuit 2, 
which thus comprises a program ID identifying register 
2a, a program area setting register 2c, and a start 
address register 2b. 



The program access control circuit 3 comprises an 
address sensor 3a, a CPU interrupt signal generator 3b, 
and a memory access disable signal generator 3c 
The address sensor 3a senses whether the 
s address is an enable address or a disable address by 
checking the address set in the program area setting 
register 1c or 2c in the first or second program access 
enable area 6ehJng circuits 1, 2 and the address being 
accessed by the currently running program. 
io When the sensing result of the address sensor 3a Is 
a disable address, the CPU internet signal generator 
3b, on the basis of the sense signal, generates a signal 
to Interrupt the CPU 5 via the system control circuit 4. 
Only when the sensing result of the address sensor 
is 3a is a disable address, the memory access disable sig- 
nal generator 3c, on the basis of the sense signal, gen- 
erate a signal to inhibit fte memory corresponding to 
the disable address from being accessed via the system 
controller 4, 

Iie-t4ii*lltx»^ 
tion, as long as a program (here, assumed to be pro- 
gram A) is running in the access enable area set in the 
first program access enable area setting circuit 1 , it is in 
normal operation. As a result, the program access con- 
as tro) circuit 3 generates no control signals, that is, neither 
an interrupt signal nor an access disable signal, to the 
CPU 5, and memories 6 to 8 via the system control cir- - 

CUlt 4. 

When program A has accessed an area other than 

so the access enable area, the sense signal from the 
address sensor 3a triggers the CPU interrupt signal 
generator 3b, which then generates an Interrupt signal 
to the CPU 5 via the system controller 4, thereby telling 
the CPU 5 the invalid accessing of program A. 

35 At the same time, the memory access disable sig- 
nal generator 3c generates an access disable signal, 
which is supplied via the system control circuit 4 to the 
ROM 6, RAM 7, and EEPROM 8, thereby inhtorting 
these memories from being accessed invalicBy. 

40 Such a series of operations of the first program 
access enable area setting circuit 1 and program 
access control circuit 3 achieves control of multi-pro- 
gram execution in such a manner that a program is 
inhibited from unnecessarily accessing another pro- 

46 gram, which is one of the objects of the invention. 

Nod, referring to the memory maps in FIGS. 2 and 
3, the memory maps and access control between pro- 
grams in a one-chfp microcomputer having a plurality of 
programs in the rnurti-program execution controlling 

so apparatus will be explained. 

First, in the map of FIG. 2, a memory map for the 
entire memory consisting of the ROM 6, RAM 7, EEP- 
ROM 8, and others is specifically sorted Into the mem- 
ory map 12 for the ROM 6, the memory map 13 for the 

55 RAM 7, and the memory map 14 for the EEPROM 8. 

As shown in these memory maps 12, 13, and 14, 
the memory map 12 for the ROM 6 contains a plurality 
of programs A, B, the memory map 14 for the EEP- 
ROM 8 contains the expansion and work areas for pro- 
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grams A, B, ... and the storage and work areas for 
programs 1,2, ...; and the memory map 18 tor the RAM 
7 contains the work areas tor programs A, 8, ... and pro- 
grams 1,2 

The system reset effected by the CPU 6 starts a 
program whose operable range is set in each of tie reg- 
isters 1a, lb, 1c in the first program access enable area 
setting circuit 1 among the plurality of programs A. 8, ... 
stored in the ROM 6. 

It is assumed that the operable range of program A 
has been set in each of the registers 1a, 1b, 1c 

To use the data processed by another program 
(here, assumed to be program B) In executing program 
A, the CPU 5, according to the instruction from program 
A, first sets the start address of program A when control 
returns from program B to program A in tie start 
address register 1b via tie address bus 9 and system 
control circuit 4. The CPU also sets the operable range 
including the start address of program B in each of the 
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This makes program A ready to operate. 
At tils time, when the address of the destination of 
tie jump from program B to program A differs from the 
setting value in the start address register 1b previously 
set tor program A, the address 6ensor 3a will sense rt 
and interrupt the CPU 5 via the CPU interrupt signal 
generator 3b and system oontrol circuit 4. 

The above operation holds true for the case where 
program A uses the data processed In another program 
C, D, ... while it is being executed. 

In the map of FIG. 3, a memory map for the mem- 
ory consisting of the ROM 6. RAM 7, EEPROM 8, and 
others is spedficaBy sorted Into the memory map 16 for 
the ROM 6, the memory map 17 for the RAM 7, and the 
memory map 18 for the EEPROM 8. 

As shown in these memory maps 16, 17, and 18, 
the memory map 16 for the ROM 6 contains the storage 

areas of a plurality of programs A, B and program 

common area A'; the memory map 16 tor the EEPROM 



enable area setting circuit 2. 

In such a specification that program A can com- 
pletely oontrol another program, such as program B, 
oontrol can jump from program A to a specific address 
in program B freely. Therefore, the CPU 5 needs not set 
the start address of program B and has only to disable 
the start address register 2b In the second program 
access enable area setting circuit 2 In which the start 
address of program B is to be set 

After these operations, the CPU 5 orders that con- 
trol should jump from program A to the allocated start 
address in program Bora specific address in program 
B, thereby switching execution from program A to pro- 
gram B. 

As long as program B is executed in the range of 
enable addresses, the address sensor 3a outputs a sig- 
nal indicating that the program is in normal operation, so 
that the CPU 5 is not interrupted and the memory 
access is not inhibited. 

When program B has accessed an address space 
other than the enable addresses invaGcfly or as a resuK 
of runaway, however, the address sensor 3a senses tie 
disable address and outputs a sense single to the CPU 
interrupt signal generator 3b and the memory access 
disable signal generator 3a 

The sense signal causes the CPU interrupt signal 
generator 3b to generate an interrupt 6ignal and the 
memory access disable signal generator 3c to generate 
an access disable signal. The interrupt signal is used to 
Interrupt the CPU 5 via the system control ctrcuft 4. The 
access disable signal is used to inn tort the memory cor- 
responding to the disable addresses from being 
accessed. 

When control returns from program B to program A, 
the CPU 5 enables the stent address register 1b of the 
first program access enable area setting circuit 1 in 
which conditions for program A have been already set 
and orders a jump from program B to program A so that 
control may return to the start address of program A. 
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K B. .... the storage and work areas for programs 1, 2, 
.... and program common area C 1 ; and the memory map 
1 7 tor the RAM 7 contains the work areas tor programs 
A, B, ... and programs 1, 2, and program common 
area B\ 

The memory map shown in FJG. 3 differs from the 
memory map in FIG. 2 in that the individual memories 
have program common areas A', B\ and C\ respec- 
tively. 

The reason for this is that because the respective 
programs are inhibited from cfirectly accessing each 
other, when a program currently being executed 
accesses another program, the switching of execution 
from one program to another is effected on the program 
common areas A', B\ and C according to specific pro- 
gram switching rules. 

First, after the CPU has reset the system, which of 
programs A, B, ... and 1, 2, ... is to be executed is spec- 
ified by the program common areas A'. B\ and C. 

A method of specifying a prioritired execution pro- 
gram may be carried out either on the basis of the exter- 
nally supplied data or according to internally fixed rules. 

For example, it is assumed that after the system 
reset, pro&am A is selected and the first program 
access enable area setting circuit 1 is allocated to pro- 
gram A. 

Then, when control is needed to switch from pro- 
gram A to another program (here, assumed to be pro- 
gram 1), the CPU 5, according to the Instruction from 
prog/am A, orders that a specific instruction or data 
items to jurrp to program 1 should be written in the pro- 
gram common area B* or C\ 

In this case, as described above; since the respec- 
tive programs are inhibited from directly accessing each 
otfier, even when program A attempts to access another 
prog/am 1 , the access will be inhibited. 

Therefore, the CPU 5 orders that control should 
move temporarily from program A to program common 
area B* or C. At the same time, on the basis of the spe- 
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ctfic instruction or data written according to the Instruc- 
tion from program A, the CPU sets tie operable range 
of program 1 1 n the respective registers 2a, 2b, and 2c In 
the second program access enable setting circuit and 
thereafter orders that control should jump to program 1 . 

Next, referring to FIGS. 4 and 5, a further detailed 
explanation will be given about access control between 
a bit map and a program in a one-chip microcomputer 
having a plurality of programs in the mutt-program exe- 
cution controlling apparatus. 

FIG. 4 shows an exanple of having a main program 
and a sub-program. 

In this example, a memory map for the entire mem- 
ory consisting of the ROM 6, RAM 7, EEPROM 8, and 
others is specifically sorted into the memory map 20 for 
the ROM 0, the memory map 21 for the RAM 7, and the 
memory map 22 for the EEPROM 8. 

As shown in these memory maps 20, 21. and 22, 
the memory map 20 for the ROM 6 contains a storage 



EEPROM 8 contains the expansion and work area for 
the main program and the storage and work area for the 
sub-program; and the memory map 21 for the RAM 7 
contains the work areas for the main program and the 
sub-program. 

First when the CPU has reset the Gyetem, this ena- 
bles the first program access enable area setting circuit 
1 and sets the operable range of the main program In 
the respective registers 1a, tlx 1c In the setting circuit 

After the system resetting, the main program starts 
to run. 

While the main program Is being executed, control 
may jump to the sub-program as the need arises and 
the data processed at the sub-program may be used in 
the main program. 

In that case, the CPU 5, according to the instruction 
from the main program, first sets the start address of the 
main program when control returns from the sub-pro- 
gram hi the start address register 1b in the first program 
access enable area setting circuit 1. At the same time, 
the CPU sets the operable range in the sift-program in 
the respective registers 2a. 2b, 2c in the second pro- 
gram access enable area setting circuit 2. 

Next, the CPU 5 orders that control should jump 
from the main program to the allocated 6tart address for 
the sub-program or a specific address in the sub-pro- 
gram. 

This switches execution from the main program to 
the sub-program. 

As long as the sub-program is executed in the 
range of enable addresses, the address sensor 3a out- 
puts a signal indicating that the program is in normal 
operation, so that the CPU 5 Is not Interrupted and the 
memory access is not inhibited. 

When the sub-program has accessed an address 
space other than the enable addresses invalidlyorasa 
result of runaway, however, the address sensor 3a 
senses the disable address and outputs the sense sin- 
gle. 



The sense signal causes the CPU interrupt signal 
generator 3b to generate an interrupt signal and the 
memory aocess disable signal generator 3c to generate 
an access disable signal. The Interrupt signal is used to 
s interrupt the CPU 5 via the system control circuit 4. The 
access disable signal is used to inhibit the memory cor- 
responding to the disable addresses from being 
accessed. 

Thereafter, when control returns from the sub-pro- 
io gram to the main-program, the CPU 5 enables the first 
program access enable area setting circuit 1 1n which 
conditions for the maJn program have been already set 
and orders a jump from the sub-program to the main 
program so that control may return to the start address 
is of the main program. 

This makes the sub-program ready to operata 
At this time, when the address of the destination of 
the jurrp from the subprogram to the main program dif- 
fers from the setting value in the start address register 

sensor 3a will sense it and interrupt the CPU 5 via the 
CPU interrupt signal generator 3b end system control 
circuit 4. 

FIG. 5 shows an example of having two programs 1 
& and 2 in the ROM 6 and two programs 3 and 4 in the 
EEPROM 8. 

In this example, a memory map 23 for the entire 
memory consisting of the ROM 6, RAM 7, EEPROM 8, 
and others Is specifically sorted into the memory map 

so 24 for the ROM 6, the memory map 25 for the RAM 7, 
and the memory map 26 for the EEPROM 8. 

As shown in these memory maps 24, 25, and 26, 
the memory map 24 for the ROM 6 contains the storage 
areas of programs 1 and 2 and program common area 

35 A'; the memory map 26 for the EEPROM 8 contains the 
expansion and work areas for programs 1 and 2, the 
storage and work areas for programs 3 and 4, and pro- 
p/am common area C*; and the memory map 25 for the 
RAM 7 contains the work areas for programs 1 to 4 and 

40 program common area B\ 

tt is assumed that after the CPU 5 has reset the 
system, program 1 is selected and the first program 
aocess enable area setting circuit 1 is allocated to pro- 
gram 1. 

as To switch from program 1 to another program (here, 
assumed to be program 3), the CPU 5, according to the 
instruction from program 1, orders that a specific 
Instruction or data item to Jump to program 3 should be 
written In the program common area 8* or C. 

so Since the respective programs are Inhibited from 
directly accessing each other, program 1 is inhibited 
from accessing the other programs 2 to 4. In this exam- 
ple, even when program 1 attempts to access another 
program 3, the access will be inhibited. 

55 Therefore, the CPU 5 orders that control should 
move temporarily from program 1 to program common 
area B* or C. At the same time* on the basis of the spe- 
cific instruction or data written according to the instruc- 
tion from program 1 , the CPU sets the operable range of 
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program 3 In the respective registers 2a, 2b, and 2c in 
the second program access enable area setting circuit 2 
and thereafter orders that control should jump to pro- 
gram 3. 

From this time on, the CPU 5 repeats the above- s 
described procedures as the need arises. 

As explained abcve, with the mutti-program execu- 
tion controlling apparatus, from the position to create 
and manage programs stored in ROMs, it Is possible to 
prevent the sub-program from accessing the main pro* 10 
gram invaOdly En a one-chip microconputer having a 
plurality of programs and assure the security of the main 
program. In addition, because there is no need of mak- 
ing the chip operating system of the one-chip microcom- 
puter known to a programmer to write the sub-program, is 
it is possible to assure the security of the chip operating 
system. ' 

Furthermore, with the multi-program execution con- 
trolling apparatus of the invention, a programmer to 

talnfng only the functions necessary for the subpro- 
gram even rf not knowing the operating system of the 
one-chip microcomputer, so that the programmer can 
create the subprocpam easily. 

Furthermore, with the multi-program execution con- as 
trolling apparatus of the Invention, even if the operation 
of the sub-program goes wrong, the adverse effect of 
the subprogram on the main program can be minimized 
because the sub-program is Inhibited from accessing 
the main program. so 

Furthermore, with the mufti-program execution con- 
trolling apparatus of the invention, the facility for creat- 
ing the sifc-prograrn remarkably widens the range of 
programmers to write the sub-program, which was 
restricted to the programmers who knew the chip oper- 35 
ating system in the prior art Just knowing the system 
operation of the CPU. programmers can write the sub- 
program, making it possible to cope with the needs 
application by application, shorten the programming 
time, and provide a variety of applications. 40 

Furthermore, with the multi-program execution con- 
trolling apparatus of the invention, from the viewpoint of 
cost, for example, by storing the subprogram in a rewri- 
table nonvolatile memory; such as an EEPROM, it is 
unnecessary to create the mask data for a ROM for as 
each application program, which was necessary in the 
prior art Instead, the mask data must be made only for 
a 6ingfe main program, which reduces the production 
cost of the mask data for each application, allowing a 
kwer programming cost 59 

Furthermore, with the mufti program execution con- 
trolling apparatus of the Invention, the time to create the 
mask data for the application is unnecessary except for 
the time required to install the subprogram for the appli- 
cation in a sarrple containing the existing main pro- ss 
gram. In addition, because the programs are inhibited 
from accessing each other, this assures the security of 
the data in each program. Therefore, for example, in the 
case of ciphered programs where security is important 



it is possible to keep the algorithm of the ciphered pro- 
gram or the method of processing the data secret from 
the other programmers, preventing not only the Invalid 
accessing of another program but also Invalid use or 
copy of the ciphered program. 

. Furthermore, with the mutoprogram execution con- 
trolling apparatus of the invention, the aforementioned 
features help enhance the effectiveness of the oopyright 
of the program, thereby protecting the owner's interests. 

Furthermore, with the muttiprogram execution con- 
trolling apparatus of the invention, it is poss&le to create 
a program valuable as a program application package, 
such as a ciphered program, which is not restricted by 
the chip operating system and particularly requires its 
security. 

By putting not only the ciphered program but also a 
ooncrete algorithm corresponding to each application in 
black boxes, their security is increased, preventing the 
value of the product from decreasing. 

for inheriting another program from accessing to putting 
programs in black boxes, the security of the program 
can be increased. 

For example, by entering by use of an IC card a 
decode key to decode the ciphered data in satellite 
broadcasting, the right to access the satellite broadcast- 
ing is obtained. 

At that time, use of the present invention prevents 
even the programmer of the main program from know- 
ing the algorithm of the ciphered program, assuring the 
security of the cipher. 

Furthermore, the IC card issuing company can 
completely entrust a cipher creating company with the 
care of the ciphering section, which eliminates the dan- 
ger of leaking the ciphering information within the IC 
card issuing company. 

Furthermore, the separation of the main program 
programmer from the ciphered program programmer 
helps enhance the security of the programs between 
them. 

As described in detail, witii the present Invention, it 
is possible to provide a muKHtfogram execution control- 
ling apparatus end method which control the execution 
of programs in a one-chip microcomputer having a plu- 
rality of programs in a manner mat inhibits a program 
from unnecessarily accessing another program and 
Increases tie security of the programs and data. 

Claims 

1. A muttiprogram execution controlGng apparatus 
comprising storage means (6, 7, 8) for storing a plu- 
rality of programs and central processing means (5) 
for controffog execution of each of the plurality of 
programs stored in the storage means (6, 7, 8), said 
apparatus characterized by further comprising: 

setting means (1c, 2c), in cooperation with the 
centra] processing means (5), for setting at 
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least one of a disable area that Inhibits access- 
ing of another program and an enable area that 
allows the accessing of another program, tn 
each of the plurality of programs stored In the 
storage means (6» 7, 8). 

2. A multi-program execution controlling apparatus 
according to daim 1, characterized in that the stor- 
age means (6, 7, 8) stores at least one main pro- 
gram and at feast one subprogram, and 

the setting means (1c, 2c) sets a disable 
area that inhibits the accessing of the subprogram 
stored in the storage means (6, 7, 8) in each pro- 
gram of the main program stored in the storage 
means (6, 7. 8). 

3. A multi-program execution controlling apparatus 
according to daim 1, characterized in that the stor- 
age means (6, 7. 8) stores at least one main pro- 

the setting means (1c, 2c) sets a tfsabfe 
area that inhibits the accessing of the main program 
stored in the storage means (6, 7, 8) in each pro- 
gram of the subprogram stored in the storage 
means (6, 7, 8). 

4. A multi-program execution controOing apparatus 
according to daim 1, characterized in that the stor- 
age means (6, 7, 8) stores at least one main pro- 
gram and at least one subprogram, and 

the setting means (1c, 2c) sets not only a 
disable area that inhibits the accessing of the sub- 
program stored in the storage means (8, 7, 8) in 
each program of the main program stored in the 
storage means (6. 7, 8), but also a disable area that 
inhibits the accessing of the main program stored in 
the storage means (6. 7, 8) in each program of the 
subprogram stored in the storage means (6, 7. 8). 

5. A rrutti-program execution controlling apparatus 
acoording to daim 1, characterized in that the stor- 
age means (6. 7, 8) stores at least one main pro- 
gram and at least one subprogram, and 

the setting means (1c, 2c) sets an enable 
area that allows the accessing of the subprogram 
stored in the storage means (6, 7, 8) in each pro- 
gram of the main program stored in the storage 
means (6, 7, 8). 

6. A multi-program execution controlling apparatus 
according to daim 1, characterized tn that the stor- 
age means (6, 7, 8) stores at least one main pro- 
gram and at least one subprogram, rod 

the setting means (1c, 2c) sets an enable 
area that allows the accessing of the main program 
stored in the storage means (8, 7, 8) in each pro- 
gram of the subprogram stored in the storage 
means (6, 7, 8). 



7. A multi-program execution controOing apparatus 
according to daim 1, characterized in that fre stor- 
age means (6, 7, 8) stores at least one main pro- 
gram and at least one subprogram, and 

s the setting means (1c, 2c) sets not only an 

enable area that allows the accessing of the sub- 
program stared in the storage means (8, 7, 8) in 
each program of the main program stored in fre 
storage means (6, 7, 8), but also an enable area 

10 that allows the accessing of the main program 
stored in the storege means (6, 7, 8) in each pro- 
gram of the subprogram stored in the storage 
means (6, 7,8). 

is 8. A multi-program execution controlling apparatus 
acoording to claim 1 , characterized by further com- 
prising identifying means (1a. 2a) tor determining 
which of the plurality of programs stored in the star* 
age means (6, 7, 6) is being executed by the central 

ito — -prdcesdr^eahs : {S)r 1 " ' . 



8. A multi-program execution controOing apparatus 
according to daim 8, characterized in tftat the iden- 
tifying means (la, 2a) indudes a program ID identi- 
zs tying register (1 a, 2a). 

10. A mutti -program execution controlling apparatus 
according to daim 2, characterized by further com- 
prising means (3b) for sensing that the cfi sable area 

30 of the main program set by the setting means (1c, 
2c) has been accessed while the subprogram 
stored in the storage means (6, 7, 8) is being exe- 
cuted by the central processing means (5), and 
notifying the sensing result to the central process- 
as ing means (5). 

11. A multi-program execution controlling apparatus 
according to daim 2, characterized by further com- 
prising means (3c) for sensing that the disable area 

40 of the main program set by the setting means (1c, 
2c) has been accessed whfle the subprogram 
stored in the storage means (8, 7, 8) is being exe- 
cuted by the central processing means (5), and 
inhibiting the access. 

46 

12. A multi-program execution controOing apparatus 
according to claim 2, characterized by further com- 
prising means (3b) for sensing that the cfisable area 
of the main program set by the setting means (1c, 

so 2c) has been accessed while the subprogram 
stored in the storege means (6, 7, 8) Is being exe- 
cuted by the central processing means (5), and 
notifying the sensing result to the central process- 
ing means (5), and 

ss means (3c) for sensing that the disable area 

of the main program set by the setting means (1c, 
2c) has been accessed while the subprogram 
stored in tie storage means (6, 7, 6) is being exe- 
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cuted by the centra) processing means (5), and 
inhibiting the access. 

13. A mufti-program execution controlling apparatus 
acoording to claim 5, characterized by further com- 6 
prising means (3b) for sensing that an area other 
than the enable area of the main program set by the 
setting means (1c, 2c) has been accessed while the 
subprogram stored in the storage means (6, 7, 6) Es 
being executed by the central processing means 10 
(5), and notifying the sensing result to the central 
processing means (5). 



14. A multi-program execution controlling apparatus 
acoording to claim 5, characterized by further com- 
prising means (3c) for sensing that an area other 
than the enable area of the main program set by the 
setting means (1c. 2c) has been accessed whQe fte 
subprogram stored in the storage means (6, 7, 8) is 
Utiiiy--eAd 



16 



(5), and inhibiting the access. 



15. A mufti-program execution controlling apparatus 
according to claim 5, characterized by further com- 
prising means (3b) for sensing that an area other ss 
than the enable area of the main program set by the 
setting means (1c, 2c) has been accessed while the 
subprogram stored In the storage means (6, 7, 8) is 
being executed by the central processing means 

(5), and notifying the sensing result to the central so 
processing means (5), and 

means (3c) tor sensing that an area other 
than the enable area of the main program set by the 
setting means (1c, 2c) has been accessed while the 
subprogram stored In the storage means (6. 7, 8) is ss 
being executed by the central processing means 
(5), and inhibiting the access. 

16. A multi-program execution controlling apparatus 
according to claim 12. characterized by further <o 
conprisrng means for causing not only the setting 
means (1c 2c) to set a disable area in the main pro- 
gram according to an instruction from the main pro- 
gam while the main program stored in the storage 
mearm (6, 7, 8) is being executed by the central 46 
processing means (5), but also the central process- 
ing means (5) to witch execution from the main 
program to the subprogram stored In the storage 
means (6. 7, 8). 

so 

17. A mufti-program execution controlling apparatus 
acoording to claim 15, characterized by further 
comprising means for causing not only the setting 
means (1c. 2c) to set an enable area in the main 
program according to an instruction from the main 56 
program whOe the main program stored in the stor- 
age means (ft 7. 8) is being executed by the central 
processing means (5). but also the central process- 
ing means (5) to switch execution from the main 



program to the subprogram 6tored in the storage 
means (6, 7, 8). 

18. A multi-program execution controlling apparatus 
comprising storage means (6, 7, 8) for storing a plu- 
rality of programs and central processing means (5) 
for controlling execution of each of the plurality of 
programs stored in the storage means (6. 7, 8), 6afd 
apparatus characterized by further comprising: 

setting means (1c, 2c), in cooperation with the 
central processing means (5), for setting a dis- 
able area that inhibits accessing of another 
program in each of the plurality of programs 
stored in the storage means (6, 7, 8); and 
control means (3), in cooperation with the cen- 
tral processing means (5), for at least one of 
interrupting to the central processing means (5) 
or inhbiting access to the storage means (6, 7, 

Bfcwhenwattertptlsr^ 

able area of another program while one of the 
plurality of programs stored in the storage 
means (6, 7, 8) is being executed. 

ia A mufti-program execution controlling apparatus 
comprising storage means (6, 7, 8) for storing a piu- 
rafity of programs and central processing means (5) 
tor controlling execution of each of the plurality of 
programs stored In the storage means (6, 7, 8), said 
apparatus characterized by further comprising: 

program ID identifying means (1a, 2a), in coop* 
eration with the central processing means (5), 
for identifying an 10 of a program to be exe- 
cuted of the plurality of programs stored in the 
storage means (6, 7, 8); 
program area setting means (1c, 2c), in coop- 
eration with the central processing means (5), 
for setting an area that allows accessing of a 
program to be executed of the plurality of pro- 
grams stored in the storage means (6. 7, 8); 
start address setting means (1c 2c). in cooper- 
ation with the central processing means (5), for 
setting an address at which operation will start 
when operation is witched to a program to be 
executed; 

address sensing means (3a) for comparing the 
address set at the program area setting means 
(1c, 2c) with an address being accessed by the 
program currently being executed to sense 
whether ft is an enable address or a disable 



interrupt signal generator means (3b) for. when 
a sensing result of the address sensing means 
(3a) shows that ft is a disable address, generat- 
ing a signal to intempt to the central process- 
ing means (5) on the basis of the sensing 
result; and 
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memory access disable signal generator 
means (3c) for, only when a sensing result of 
the address sensing means (3a) shows that 
access is intended for a disable address, gen- 
erating a signal to inhibit access to the storage $ 
means (6, 7, 8) corresponding to the disable 
address. 

3). A multi-program execution controlling method char- 
acterized by comprising the stops of: to 

identifying, in cooperation with a centra) 
processing means (5), an ID of a program to be 
executed of a plurality of programs stored in a 
storage means (6, 7, 8); is 
setting, in cooperation with the central process- 
ing means (5), an area that allows accessing of 
a program to be executed of the plurality of pro- 
grams stored in the storage m eans (6, 7, 3); 

- - -Sfettinfr-irt bboperatitin mftmMlpd BBF^B 

tng means (5), an address at which operation 
will start when operation is switched to a pro- 
gram to be executed; 

comparing the address set at the settfcg step 
with an address being accessed by the pro- 2s 
gram currently being executed to 6ense 
whether it Is an enable address or a disable 
address; 

generating a signal to interrupt to the central 
processing means (5), when a sensing result at so 
the sensing step shows that access 16 indented 
for a disable address, on the basis of the sens- 
ing result; and 

generating a signal to inh&t access to the stor- 
age means (6, 7, 8) corresponding to the cfisa- 33 
bfe address, only when a sensing result at the 
sensing step shows that access is intended for 
a disable address. 
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